package com.itheima.mapper;

import com.itheima.pojo.StuRequestParam;
import com.itheima.pojo.Student;
import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;
import java.util.Map;

@Mapper
public interface StuMapper {
    /**
     * 条件分页查询学生信息
     * */
    List<Student> list(StuRequestParam stuRequestParam);

    /**
     * 删除学生信息
     * */
    void deleteByIds(List<Integer> ids);

    /**
     * 添加学生信息
     * */
    void add(Student student);

    /**
     * 根据id查询学生信息
     * */
    @Select("select * from student where id = #{id}")
    Student selectById(Integer id);

    /**
     * 修改学生信息
     * */
    void update(Student student);

    /**
     * 修改学生违规次数和信息并更新最后修改时间
     * */
    void updateViolation(Integer id, Integer score);

    /**
     * 获取学生各学历的统计数据
     * */
    @MapKey("degree")
    List<Map<String, Object>> getStuDegreeReport();

    /**
     * 获取学生各班级的人数统计数据
     * */
    @MapKey("clazzName")
    List<Map<String, Object>> getStudentCountData();

    /**
     * 根据班级id查询学生数量
     * */
    @Select("select count(*) from student where clazz_id = #{id}")
    Integer selectByClazzId(Integer id);
}
